csv - Pig CSVExcelStorage 双引号逗号
全部标签 我正在尝试解析从Excel电子表格生成的CSV文件。这是我的代码require'csv'file=File.open("input_file")csv=CSV.parse(file)但是我得到这个错误ArgumentError:invalidbytesequenceinUTF-8我认为错误是因为Excel将文件编码为ISO8859-1(Latin-1)而不是UTF-8谁能帮我解决这个问题提前致谢。 最佳答案 您需要告诉Ruby该文件在ISO-8859-1中。将您的文件打开行更改为:file=File.open("input_file
我有一组ActiveRecord模型,我希望将其转换为CSV。我尝试研究像FasterCSV这样的gem,但它们似乎只适用于字符串和数组,而不适用于ActiveRecord模型。简而言之,我要转换:user1=User.firstuser2=User.lasta=[user1,user2]收件人:id,username,bio,email1,user1,user1bio,user1email1,user2,user2bio,user2email有没有简单的Rails方法可以做到这一点? 最佳答案 下面将所有用户的属性写入一个文件:C
我有一个非常大的字符串,需要转义其中的所有单引号,因此我可以将它提供给JavaScript而不会打乱它。我无法控制外部字符串,因此无法更改源数据。例子:Coted'Ivoir->Coted\'Ivoir(实际字符串很长,包含很多单引号)我试图通过在字符串上使用gsub来实现这一点,但无法让它工作:a="Coted'Ivoir"a.gsub("'","\\\'")但这给了我:=>"CotedIvoirIvoir"我也试过:a.gsub("'",92.chr+39.chr)但得到了相同的结果;我知道这与正则表达式有关,但我从来没有得到它们。 最佳答案
我正在尝试弄清楚如何从RubyCSV中获取当前行/行号。这是我的代码:options={:encoding=>'UTF-8',:skip_blanks=>true}CSV.foreach("data.csv",options,)do|row,i|putsiend但这似乎并没有按预期工作。有办法做到这一点吗? 最佳答案 由于当前Rubies中CSV的更改,我们需要进行一些更改。在2.6之前使用Ruby的原始解决方案的答案中进一步查看。以及with_index的使用,无论版本如何,它都可以继续工作。对于2.6+这将有效:require'
是否可以将默认字段分隔符从逗号更改为其他字符,例如用于导出的'|'? 最佳答案 下面是一个使用选项卡的示例。到一个文件:CSV.open("myfile.csv","w",{:col_sep=>"\t"})do|csv|csv到一个字符串:csv_string=CSV.generate(:col_sep=>"\t")do|csv|csv这是关于CSV的当前文档:http://ruby-doc.org/stdlib/libdoc/csv/rdoc/index.html 关于ruby-使用R
我正在使用ruby1.9.2我正在尝试解析包含一些法语单词(例如spécifié)的CSV文件,并将内容放入MySQL数据库中。当我从CSV文件中读取行时,file_contents=CSV.read("csvfile.csv",col_sep:"$")返回的元素是ASCII-8BIT编码的字符串(spécifié变为sp\xE9cifi\xE9),然后像“spécifié”这样的字符串没有正确保存到我的MySQL数据库中。YehudaKatz表示ASCII-8BIT实际上是“二进制”数据,这意味着CSV不知道如何读取适当的编码。所以,如果我尝试让CSV强制编码如下:file_cont
我们允许用户通过csv导入数据(使用ruby1.9.2,因此它是更快的csv)。作为用户数据,当然,它可能没有得到适当的清理。当我们尝试在/index方法中显示数据时,我们有时会收到错误“UTF-8中的无效字节序列”,指向我们显示字段widget.name之一的erb当我们进行导入时,我们希望强制传入的数据有效...是否有一个ruby运算符可以将字符串映射到有效的utf8字符串,例如,类似goodstring=badstring.no_more_invalid_bytes“坏”数据的一个示例是char,它看起来像连字符,但不是常规的ascii连字符。我们更愿意将非utf-8字符
我想解析一个CSV文件,以便每一行都被视为一个对象,标题行是对象中属性的名称。我可以写这个,但我确定它已经在那里了。这是我的CSV输入:"foo","bar","baz"1,2,3"blah",7,"blam"4,5,6代码看起来像这样:CSV.open('my_file.csv','r')do|csv_obj|putscsv_obj.foo#prints1the1sttime,"blah"2ndtime,etcputscsv.bar#prints2thefirsttime,7the2ndtime,etcend使用Ruby的CSV模块,我相信我只能通过索引访问字段。我认为上面的代码会更
我有一个数组:array=["10","20","50","99"]我想将它转换成一个简单的以逗号分隔的字符串列表,如下所示:"10","20","50","99" 最佳答案 array.join(',')几乎可以满足您的要求;它不会保留值周围的引号或后面的空格。用于保留引号和空格:array.map{|item|%Q{"#{item}"}}.join(',')这将打印"\"10\",\"20\",\"50\",\"99\""。假设问题实际上需要单个字符串,转义引号是必要的。关于%Q的文档:stringliterals.您可以使用i
如何转义字符串中的单引号和双引号?我想一起转义单引号和双引号。我知道如何分别通过它们,但不知道如何同时通过它们。例如:str="ruby'onrails""=ruby'onrails" 最佳答案 我的首选方法是不用担心转义,而是使用%q,它的行为类似于单引号字符串(没有插值或字符转义),或者%Q对于双引号字符串行为:str=%q[ruby'onrails"]#likesingle-quotingstr2=%Q[quotingwith#{str}]#likedouble-quoting:willinsertvariable参见ht